javascript oop、instanceof 和基类
全部标签 我目前有一个派生类和一个基类。如何使派生类的基类等于我拥有的基类?浅拷贝有用吗?classBase{privatestringname;publicstringName{get;set;}privatestringaddress;publicstringAddress{get;set;}}classDerived:Base{privatestringfield;publicStringfield{get;set;}}namespaceConsoleApplication1{classProgram{staticvoidMain(string[]args){Baseb=newBase()
C#语言规范说,如果我继承了一个类,并且基类和派生类具有相同的命名成员和相同的签名,那么我必须使用new关键字来隐藏基类成员(还有一种方法是在基类和派生类成员中使用virtual和override关键字)。但在实践中我发现,如果派生类具有相同的命名成员,则派生类会自动隐藏派生成员。那么同名派生类成员中的新关键字的主要好处和问题是什么? 最佳答案 如您所述,不需要新的。它是可选的,如果您不使用它,您会收到警告。乍一看这是一个奇怪的设计决定,您是完全正确的。此设计决策的目的是帮助缓解称为“脆弱基类”问题的一类问题。这是该问题的一个版本:
为什么C#空合并运算符无法解决这个问题?Catc=newCat();Dogd=null;Animala=d??c;这会报错运算符??不能应用于Dog和Cat类型的操作数考虑到以下编译,这看起来很奇怪。Animala=d;a=c;上下文代码如下:publicabstractclassAnimal{publicvirtualvoidMakeNoise(){Console.WriteLine("noise");}}publicclassDog:Animal{publicoverridevoidMakeNoise(){Console.WriteLine("wuff");}}publicclas
我希望能够找到特定类型的所有父类型(基类和接口(interface))。EG如果我有classA:B,C{}classB:D{}interfaceC:E{}classD{}interfaceE{}我想知道A是BCDandEandObject最好的方法是什么?有没有一种反射(reflection)方法可以做到这一点,或者我需要自己做点什么。====编辑====是这样的吗?publicstaticIEnumerableParentTypes(thisTypetype){foreach(Typeiintype.GetInterfaces()){yieldreturni;foreach(Typ
我有类层次结构是这样的情况,+---------------+|UIElement||---------------|+----------------------+|...||MyWindowsApplication|SomePropert{}||----------------------|||现在在我的应用程序(以及我可以导出此MyUserControl的所有其他应用程序)中,我可以设置由MyUserControl类而不是处理的SomePropertyUIElement?我现在通过为MyUserControl创建一个对象并将其分配给我在我的xaml页面中添加的控件来执行此操作。所
我正在尝试实现IEnumerable在派生自已实现IEnumerable的基类的类中.为什么会调用base.Cast()(或基本元素上的任何LINQ方法)在类Turtle的任何方法中编译失败?不可能替换base与this因为它显然会导致StackOverflowException.以下是重现该问题的最小代码示例:publicinterfaceIAnimal{}publicclassAnimal:IAnimal{}publicclassTurtle:Animal{}publicclassAnimalEnumerable:IEnumerable{ListAnimals=newList();
是否可以对需要实现构造函数(带参数)的派生类强制执行编译时契约?我有一个基类,它的构造函数需要一个参数:publicclassFooBase{protectedintvalue;publicFooBase(intvalue){this.value=value;}publicvirtualvoidDoSomething(){thrownewNotImplementedException();}}我想强制派生我的基类来实现相同的构造函数:publicclassFoo:FooBase{publicFoo(intvalue):base(value){}publicoverridevoidDoS
我正在学习C#,但遇到了以下问题。我有两个类:基类和派生类:classMyBase{publicvoidMyMethod(){Console.WriteLine("MyBase::MyMethod()");}}classMyDerived:MyBase{publicvoidMyMethod(){Console.WriteLine("MyDerived::MyMethod()");}}目前,没有virtual和override关键词。当我编译它时,我收到警告(这当然是预期的)我试图从MyBase类中隐藏MyMethod。我想做的是从具有派生类实例的基类调用方法。我这样做是这样的:MyDe
我的基类有一个公共(public)静态方法,但是当我调用typeof(TDerived).GetMethods(BindingFlags.Public|BindingFlags.Static)时,我的方法没有返回。(TDerived当然以某种方式继承self的基类)。我在此查询的位置没有对我的基类的引用。我做错了什么? 最佳答案 使用BindingFlags.FlattenHierarchy标志:typeof(TDerived).GetMethods(BindingFlags.Public|BindingFlags.Static|B
我第一次看到一位同事在实现对象池时这样做。他将要被池化的类作为参数传递给通用基类。这个基类列出了池化代码。奇怪的是基类会知道它的子类。在每个正常情况下,这都被认为是不好的做法。但在这种情况下,parent只是一种避免编写重复代码的技术解决方案。基类永远不会被任何其他代码引用。这种构造的一个缺点是它“烧掉了基类”。您不能在层次结构的中间引入通用基类。这个问题可能超出了主题。下面是一个可以想象的例子:publicabstractclassSingletonwhereT:class{publicstaticTInstance{get;privateset;}publicSingleton()